package com.example.xpvideo.service.serviceImpl;

import com.example.xpvideo.entity.SpecialArea;
import com.example.xpvideo.mapper.SpecialAreaMapper;
import com.example.xpvideo.service.SpecialAreaService;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.stereotype.Service;
import org.springframework.transaction.annotation.Transactional;

import java.util.List;

/**
 * 本地生活商品专区表(SpecialArea)Service层
 *
 * @author 
 * @since 2021-09-17 01:50:48
 */
@Service
 @Transactional(rollbackFor = {RuntimeException.class, Exception.class})
public class SpecialAreaServiceImpl implements SpecialAreaService {
        @Autowired
        private SpecialAreaMapper specialAreaMapper;


 /**
     * 通过ID和其他条件查询单条数据
     *
     * @param specialArea 实例对象
     * @return 实例对象
     */
       @Override
 @Transactional(rollbackFor = {RuntimeException.class, Exception.class})
     public SpecialArea querySpecialAreaLimit1(SpecialArea specialArea){
     return  specialAreaMapper.querySpecialAreaLimit1( specialArea);
     }
     
 /**
     * 查询指定行数据
     * @param specialArea 实例对象
     * @param offset 查询起始位置
     * @param limit 查询条数
     * @return 对象列表
     */
       @Override
 @Transactional(rollbackFor = {RuntimeException.class, Exception.class})
  public   List<SpecialArea> queryAllSpecialAreaByLimit( SpecialArea specialArea, Integer offset,  Integer limit){
   return specialAreaMapper.queryAllSpecialAreaByLimit(specialArea, offset,limit);
  }

  /**
     * 查询数据条数
     * @return 条数
     */
       @Override
 @Transactional(rollbackFor = {RuntimeException.class, Exception.class})
   public int countAllSpecialArea(SpecialArea specialArea){
   return specialAreaMapper.countAllSpecialArea( specialArea);
   }
   /**
     * 通过实体作为筛选条件查询
     *
     * @param specialArea 实例对象
     * @return 对象列表
     */
       @Override
 @Transactional(rollbackFor = {RuntimeException.class, Exception.class})
   public List<SpecialArea> queryAllSpecialArea(SpecialArea specialArea){
   return specialAreaMapper.queryAllSpecialArea(specialArea);
   }
  /**
     * 新增数据
     *
     * @param specialArea 实例对象
     * @return 影响行数
     */
     @Override
   @Transactional(rollbackFor = {RuntimeException.class, Exception.class})
    public int insertSpecialArea(SpecialArea specialArea){
    return  specialAreaMapper.insertSpecialArea( specialArea);
    }
  /**
     * 修改数据
     *
     * @param specialArea 实例对象
     * @return 影响行数
     */
       @Override
 @Transactional(rollbackFor = {RuntimeException.class, Exception.class})
     public  int updateSpecialArea(SpecialArea specialArea){
         return specialAreaMapper.updateSpecialArea( specialArea);
     }

    /**
     * 通过主键删除数据
     * @param id 主键
     * @return 影响行数
     */
      @Override
  @Transactional(rollbackFor = {RuntimeException.class, Exception.class})
   public  int deleteSpecialAreaById(Integer id){
   return  specialAreaMapper.deleteSpecialAreaById( id);
   }
     /**
     * 通过主键列表删除，列表长度不能为0
     * @param list 集合
     * @return 条数
     */
      @Override
  @Transactional(rollbackFor = {RuntimeException.class, Exception.class})
  public  int deleteSpecialAreaByIds( List<Integer> list){
    return  specialAreaMapper.deleteSpecialAreaByIds(  list);
  }
    
       /**
     * 通过主键修改实体列表，列表长度不能为0，注意：当实体属性为null时，对应的列也会别更新为null
     * @param list 集合
     * @return 条数
     */
       @Override
 @Transactional(rollbackFor = {RuntimeException.class, Exception.class})
   public int updateSpecialAreaBatch( List<SpecialArea> list){
   return  specialAreaMapper.updateSpecialAreaBatch(list);
   }
    /**
     * 批量其他列,除主键以外的列，列表长度不能为0,字段是空的就置为null
     * @param list 集合
     * @return 条数
     */
      @Override
  @Transactional(rollbackFor = {RuntimeException.class, Exception.class})
 public   int insertSpecialAreaBatch( List<SpecialArea> list){
 return specialAreaMapper.insertSpecialAreaBatch( list);
 }
      /**
     * 通过实体非空属性删除
     * @param specialArea  实体
     * @return 条数
     */
        @Override
@Transactional(rollbackFor = {RuntimeException.class, Exception.class})
  public   int deleteSpecialAreaByEntity( SpecialArea specialArea){
  return  specialAreaMapper.deleteSpecialAreaByEntity(  specialArea);
  }
    /**
     * 通过实体不为空的属性作为筛选条件查询列表
     * @param specialArea  实体
     * @return list
     */
       @Override
 @Transactional(rollbackFor = {RuntimeException.class, Exception.class})
   public  List<SpecialArea> listSpecialAreaByEntity(SpecialArea specialArea){
   return specialAreaMapper.listSpecialAreaByEntity( specialArea);
   }

 /**
     * 新增实体属性不为null的列
     * @param specialArea  实体
     * @return 条数
     */
       @Override
 @Transactional(rollbackFor = {RuntimeException.class, Exception.class})
   public  int insertSpecialAreaSelect( SpecialArea specialArea){
      return specialAreaMapper.insertSpecialAreaSelect( specialArea);

   }
   
      /**
     * 批量新增新增实体属性不为null的列
     * @param list  实体
     * @return 条数
     */
        @Override
@Transactional(rollbackFor = {RuntimeException.class, Exception.class})
  public  int insertSpecialAreaListSelect( List<SpecialArea> list){

     return specialAreaMapper.insertSpecialAreaListSelect( list);
      }
     /**
     * 通过实体不为空的属性作为筛选条件查询单个
     * @param specialArea  实体
     * @return 单个
     */
     @Override
   @Transactional(rollbackFor = {RuntimeException.class, Exception.class})
    public  SpecialArea getSpecialAreaByEntity(SpecialArea specialArea){
     return  specialAreaMapper.getSpecialAreaByEntity(specialArea);
    }

}

